package com.xie.leetcode.array;

//260. 只出现一次的数字 III
//        给定一个整数数组 nums，其中恰好有两个元素只出现一次，其余所有元素均出现两次。 找出只出现一次的那两个元素。你可以按 任意顺序 返回答案。
//
//
//
//        进阶：你的算法应该具有线性时间复杂度。你能否仅使用常数空间复杂度来实现？
//
//
//
//        示例 1：
//
//        输入：nums = [1,2,1,3,2,5]
//        输出：[3,5]
//        解释：[5, 3] 也是有效的答案。
//        示例 2：
//
//        输入：nums = [-1,0]
//        输出：[-1,0]
//        示例 3：
//
//        输入：nums = [0,1]
//        输出：[1,0]
//        提示：
//
//        2 <= nums.length <= 3 * 104
//        -231 <= nums[i] <= 231 - 1
//        除两个只出现一次的整数外，nums 中的其他数字都出现两次

import java.util.Arrays;
import java.util.HashMap;
import java.util.Map;

/**
 * @author xiezhendong
 * @date 2021/10/21
 */
public class SingleNumber2 {

    public static void main(String[] args) {
        SingleNumber2 singleNumber2 = new SingleNumber2();
        System.out.println(Arrays.toString(singleNumber2.singleNumber(new int[]{1, 2, 1, 3, 2, 5})));
        System.out.println(Arrays.toString(singleNumber2.singleNumber(new int[]{-1, 0})));
        System.out.println(Arrays.toString(singleNumber2.singleNumber(new int[]{0, 1})));
    }

    public int[] singleNumber(int[] nums) {
        if (nums == null || nums.length <= 2) {
            return nums;
        }

        Map<Integer, Integer> numMap = new HashMap<>();
        for (int num : nums) {
            if (numMap.get(num) != null) {
                numMap.put(num, numMap.get(num) + 1);
            } else {
                numMap.put(num, 1);
            }
        }

        int num = 0;
        int[] numNew = new int[2];
        for (Map.Entry<Integer, Integer> entry : numMap.entrySet()) {
            if (entry.getValue() == 1) {
                numNew[num] = entry.getKey();
                num++;
            }
        }
        return numNew;
    }
}
